<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <div id="app">
      <my-comp></my-comp>
    </div>
  </body>
  <script src="./node_modules/vue/dist/vue.js"></script>
  <script>
    /*
      组件其实就是一个对象
      组件的实例化过程 会通过当前传入的对象 创建出一个实例来
    */
    // 通过配置对象创建出一个构造函数
    // 通过 new 可以实例化出当前实例
    const Ctor = Vue.extend({
      template: `
      <div>{{ msg }}</div>
     `,
      data() {
        return {
          msg: 'Hello'
        }
      }
    })

    document.body.appendChild(new Ctor().$mount().$el)

    Vue.component('my-comp', Ctor)

    const vm = new Vue({
      el: '#app'
    })
  </script>
</html>
